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AMENDMENTS TO THE CLAIMS 

1. (Currently Amended) A method for providing parallel execution of computing tasks in a 
heterogeneous computing environment comprising: 

partitioning a computing task into small tasks; 

assigning the small tasks to mobile agents; 

determining available computing hosts in the heterogeneous computing environment; 
transferring the mobile agents to the available computing hosts; 

executing the mobile agents at the available computing hosts using *he execution eed* 
code provided to the mobile agents from a central serv er: and 

maintaining stack trace and state information abou t each of the mobile agents to allow 
one or more of the mobile agents to be reconstructed at an alternate computing host using the 
stack trace and state information. 

2. (Original) The method of claim 1, wherein the step of determining available computing hosts 
further comprises determining network latency. 
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3. (Currently Amended) The method of claim 1, further comprising transferring execution code 
from a the central server to virtual machines at the available computing hosts 

4. (Original) The method of claim 1, wherein the step of executing the mobile agents is 
performed in virtual machines at the computing hosts without modification of the virtual 
machines. 

5. (Original) The method of claim 1, wherein one of the small tasks is assigned to one of the 
mobile agents. 

6. (Original) The method of claim 3, wherein the step of transferring execution code is 
performed in response to a request by a mobile agent. 

7. (Original) The method of claim 6, wherein the step of transferring execution code is 
performed by a web server, 

8. (Original) The method of claim 1 further comprising monitoring execution of the mobile 
agents at the available computing hosts* 

9. (Currently Amended) The method of claim 1 further comprising allowing the mobile agents 
to collaborate over the heter e og e n e ous heterogeneous computing environment as the mobile 
agents execute at the available computing hosts. 
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10. (Original) The method of claim 1, wherein the mobile agents are executed in real time. 

11. (Currently Amended) A method for providing parallel computing using mobile agents 
comprising: 

brooking a comput e r task into - amall tasko; 

assigning tho small tarries a computing task to one or more mobile agents; 
transferring the one or more mobile agents to one or more available computing hosts; 
transferring execution code from a central server to the one or more available computing 

hosts; 

executing the one or more mobile agents at the one or more available computing hosts 
using the execution code; and 

storing stack trace and real-time state information about the one or more mobile agents at 
a first alternate computing host on which none of the one or more mobile agen ts are executing as 
ifr n m n N! n ngrttiir Q vnnntn ni thfl computing hosts, to allow the one or more mobile agents to be 
reconstructed at a second alternate computing host. 
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12. (Original) The method of claim 11 further comprising, prior to transferring the mobile 
agents, the steps of: 

determining network latency affecting transmission of data between computing hosts; and 
halting transfeiriug of the mobile agents if network latency exceeds a threshold. 

13. (Original) The method of claim 12 further comprising, prior to transferring the mobile 
agents, the steps of: 

monitoring utilization of the computing hosts; and 

halting transferring of the mobile agents if utilization of computing hosts exceeds a 
threshold, 

14. (Currently Amended) A method for migrating a software application running in a virtual 
machine from a primary host to a secondary host comprising: 

constructing an application using at looot one mobile agont; a plurality of mobile agents; 

transferrins the plurality of mobile a gents to a first computing host: 

executing the plurality of mobile agents at the first computing host; 
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n^nb^ing .tack trace an* state information about each of the p lurality of mobile agents 
a second computin g boat on which none of the p lurality of mobile agents are executing 

detecting an indication to migrate the application; and 

in response to the indication, migrating the application in its entirety from the primary 
first computing host to the secondary a third computing host without modifying the virtual 
a virtual machine at the third comp uting host bv reconstructing each of the plurality of 
mobile age nts at the third c omputing host usinf the stack t race and state information. 

15. (Original) The method of claim 14 wherein the indication comprises an indication of 
network latency. 

16. (Original) The method of claim 14 wherein the indication comprises an indication of hostile 
attack. 

17. (Original) The method of claim 16 wherein the hostile attack comprises hacking. 

18. (Original) The method of claim 14 wherein the indication comprises an indication of 
network failure. 
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19. (Original) The method of claim 14 wherein the indication comprises an indication of 
computer hardware failure. 

20. (Currently Amended) The method of claim 14 further comprising resuming execution of the 
mobile agent at the secondary third computing host at a pointwhere execution was halted. 

21. (Currently Amended) The method of claim 20, wherein i nfor mation about tho mobile ngw* 
L ujed t o rc c umo nrrn i ti"" nf thn ™ nhi1n n rr nt tho '"formation obout a mobile ag e nt 
comprising thf. stack trace and state information c omprises information about an execution 
thread of the mobile agent as it existed at a computing the first host prior to being transferred to 
the Ihirjd. secondary computing hoot, tho information boing reconstructed at tho oooondary 
oomputing host aftor tho mobilo agent is tranoforrod to tho oooondary computing host. 

22. (Cancelled) 

23. (Cancelled) 

24. (Cancelled) 

25. (Original) The method of claim 14 further comprising: 

continuing monitoring for another indication to migrate the application; 
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continuing migrating the application to other hosts. 

26. (Currently Amended) A computer system apparatus for providing parallel execution of 
computing tasks in a heterogeneous aotwork computing environment comprising: 

a dispatcher for partitioning the computing task into a plurality of small tasks and 
dispatching the small tasks; 

mobile agents for receiving small tasks from the dispatcher, 

computing resources on a network including virtual maohin e s; machines for executing 
mobile agent software code; 

means for transferring the mobile agents to the computing resources; and 

means for transferring execution code from a central server to the computing resources, 
the computing resources receiving and executing one of the small tasks assigned to a mobile 
agent in the virtual machines using the execution eedfc code and the means for transferring 
execution code maintaining stack trace and state information ab out each of the mobile agents at a 
first alternate computing host where none of the mo b ile agents are executing to allow each of the 
mobile agents to be reconstructed at a second alternate computing host. 



27. (Cancelled) 
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28. (Original) The apparatus of claim 26 wherein the central seiver comprises a web server. 

29. (Original) The apparatus of claim 26 further comprising means for monitoring execution of 
the small tasks. 

30. (Original) The apparatus of claim 26 further comprising collaboration means for allowing 
the mobile agents to communicate and share information in real time. 

3 1 . (Original) The apparatus of claim 26, wherein the mobile agents execute in real time. 

32. (Original) The apparatus of claim 26, further comprising storage means for storing real time 
stale information about the mobile agents as the mobile agents execute at the computing 



resources. 



33. (Original) The apparatus of claim 26 further comprising: 

means for monitoring execution of the mobile agents at the computing hosts; and 

means for detecting over-utilization of one of the computing hosts and for issuing a 
warning when one of the computing hosts is over-utilized. 
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34. (Currently Amended) A method for providing realistic thread migration which comprises: 
instantiating a mobile agent thread at a first computing host; 
processing the mobile agent thread at the first computing host; 

storing *t*ck trace and state information about the mobile agent thread at a second 
im puting host at which the mobi ^ ? ff»"t thread & trot executing as the mobile agent thread 
ftvfloutac: executes at the first c omputing host: 

detecting an indication to migrate the mobile agent thread; and 
in response to the indication, 

stopping execution of the mobile agent thread; aad 

- transferring tbe execution code for the m o bile agent thread from a central server 
to a third computing host; and 

transferring the stack trace and state information about the mobile agent thread to 
a the third oooond computing host. 

35. (Cancelled) 
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36. (Cancelled) 

37. (Cancelled) 

38. (Currently Amended) The method of claim 39 34 further comprising: 



receiving ihe stack trace and state information about the mobile agent thread at the flM 
computing sooond host; 

reconstructing the mobile agent thread at the third computing seeoad host using the stack 
trace and state information about the mobile agent thread; and 

continuing processing of the mobile agent thread at the sooond thM computing host at a 
point at which execution of the thread was stopped at the first computing host. 

39. (Currently Amended) The method of claim 38 wherein the step of transferring the stack 
trace and state information about the mobile agent thread further comprises serializing the 
information about the mobile agent thread. 
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40. (Currently Amended) An agent collaboration environment which comprises: 
a plurali ty of mobile agents; 

a » flf rftnr dehnp per for storing stack t m c* and state information about each of the plurality 
nf mobile agents At a computing ho st where none of the plurality of mobile agents are executing; 

a conference room for providing a virtual workspace for the mobile agents; and 

a registration subsystem for selectively assigning the plurality of mobile agents to the 
conference room, 

wherein each of the plurality of agents can share data, information, and results of 
computations in the conference room. 

41. (Original) The agent collaboration environment of claim 40, wherein the conference room 
monitors and moderates communication between the plurality of mobile agents. 
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42. (New) A method for dynamically constructing and executing a computer application in a 
heterogeneous computing environment using mobile agents comprising: 

constructing a computer application using mobile agents; 

storing the mobile agents at a central server; 

dispatching the mobile agents from the central server to an available computing host on 
the heterogeneous computing environment using a dispatching component; 

allowing the mobile agents to execute at the available computing host; and 

monitoring execution of each of the plurality of mobile agents and storing stack trace and 
state information about execution of the mobile agents at a computing host where none of the 
mobile agents are executing. 

43. (New) The method of claim 42, further comprising monitoring CPU utilization and network 
latency prior to dispatching the mobile agents. 

44. (New) The method of claim 42, further comprising providing a collaboration environment 
for allowing the mobile agents to exchange information in real time. 
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45. (New) The method of claim 42, wherein the step of allowing the mobile agents to execute at 
the available computing hosts comprises allowing the mobile agents to execute at the available 
computing host without requiring prior installation of executable code at the available computing 
host. 

46. (New) The method of claim 1, further comprising reconstructing one or more of the mobile 
agents at the second computing host using the stack trace and state information stored at the first 
computing host. 

47. (New) The method of claim 11, wherein the step of transferring the one or more mobile 
agents to one or more available computing hosts comprises transferring data relating to the one 
or more mobile agents to the one or more mobile computing hosts. 

48. (New) The method of claim 26, wherein the means for transferring the mobile agents to the 
computing resources comprises means for transferring data relating to the mobile agents to the 
computing resources. 

49. (New) The apparatus of claim 28, wherein the web server is located at a first organization. 

50. (New) The apparatus of claim 49, further comprising an agent execution environment 
located at a second organization. 



14 



925199.01 



PAGE 1804 » RCVD AT 1218/2004 3:46:28 PM [Eastern Standard Time] * SVR:USPT0-EFXRF-1/1 ' DNIS:8729306 ' CSID: 1 9/3/40140/ * DURATION (mm-ss):0748 



DEO08-2004 16=04 



LJOLFF & SAMSON 



19737401407 P. 19/34 



51. (New) The apparatus of claim 50, further comprising firewalls at the first and second 
organizations to allow execution code for the mobile agents to be exchanged between the first 
and second organizations. 
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